# Συστήματα Μικροϋπολογιστών 2023-24 — 2η Ομάδα Ασκήσεων

Κόρδας Νικόλαος - Α.Μ.: 03121032 Κριθαρίδης Κωνσταντίνος - Α.Μ.: 03121045

17 Απριλίου 2024

#### $1^{\eta}$ ASKHSH

### Ερώτημα (α)

Στο ερώτημα αυτό καλούμαστε να αποθηκεύσουμε τους αριθμούς 0 - 127 σε διαδοχικές θέσεις μνήμης, ξεκινώντας από την 0900Η (δίνεται στην εκφώνηση). Αυτό το πετυχαίνουμε με τον κώδικα:

IN 10H
MVI A,00H; A register is our counter
LXI B,0900H; Ad counter
L1:

STAX B INR A INR C CPI 80H JC L1

END

Πιο συγκεκριμένα, αρχικά απενεργοποιούμε την προστασία της μνήμης (IN 10H) και στη συνέχεια αρχικοποιούμε τον μετρητή από το 0 έως το 127 στον καταχωρητή Α και τον μετρητή για τις διευθύνσεις μνήμης στο ζεύγος καταχωρητών Β-C (διότι οι διευθύνσεις έχουν μέγεθος 2 byte). Στην συνέχεια, στην αρχή κάθε επανάληψης που ξεκινά στην ετικέτα L1 αποθηκεύουμε το περιεχόμενο φορτώνουμε το περιεχόμενο του Α (μετρητή 0 - 127) στην θέση μνήμης που έχει αποθηκεύσει το ζεύγος καταχωρητών Β-C, και στη συνέχεια αυξάνονται και τα 2 κατά 1. Προσοχή, για να αυξηθούν σωστά οι θέσεις μνήμης, αρκεί να αυξήσω μόνο το κάτω byte, τον C δηλαδή. Τέλος, ελέγχουμε αν ο μετρητής Α είναι μικρότερος από 128 και εφόσον είναι εκτελούμε πάλι την ίδια διαδικασία, ενώ αν όχι τερματίζουμε το πρόγραμμα. Επιβεβαιώνουμε την ορθότητα του προγράμματός μας ελέγχοντας τις αλλαγές που επιτελεί στη RAM. Συγκεκριμένα:

```
0900
      00 0901
                01 0902
                          02 0903
                                    03
0904
      04
         0905
                05 0906
                          06 0907
                                    07
0908
      08 0909
                09 090A
                          0A 090B
                                    0B
090C
      OC 090D
                0D 090E
                          0E 090F
                                    0F
0910
      10 0911
                11 0912
                          12 0913
                                    13
0914
         0915
                15 0916
                             0917
      14
                          16
                                    17
0918
      18 0919
                19 091A
                          1A 091B
                                    1B
091C
      1C 091D
                1D 091E
                          1E 091F
                                    1F
0920
      20 0921
                21 0922
                          22
                             0923
                                    23
0924
      24 0925
                25 0926
                          26 0927
                                    27
0928
      28
         0929
                29 092A
                             092B
                                    2B
                          2A
092C
      2C 092D
                          2E 092F
                                    2F
                2D 092E
0930
      30 0931
                31
                   0932
                          32
                             0933
                                    33
                          36
0934
      34
         0935
                35 0936
                             0937
                                    37
0938
         0939
      38
                39 093A
                          3A
                             093B
                                    3B
093C
      3C 093D
                3D 093E
                          3E 093F
                                    3F
0940
      40
         0941
                    0942
                          42
                             0943
                41
                                    43
0944
         0945
                45 0946
                             0947
                                    47
      44
                          46
0948
      48
         0949
                49
                   094A
                          4Α
                             094B
                                    4B
094C
      4C 094D
                4D 094E
                          4E 094F
                                    4F
0950
      50
         0951
                51
                   0952
                          52
                             0953
                                    53
0954
      54
         0955
                55
                   0956
                          56
                              0957
                                    57
0958
      58
         0959
                59
                   095A
                          5A 095B
                                    5B
095C
      5C 095D
                5D 095E
                          5E 095F
                                    5F
0960
      60 0961
                61
                   0962
                          62 0963
                                    63
0964
      64
         0965
                65
                   0966
                          66
                             0967
                                    67
0968
      68
         0969
                69
                   096A
                          6A 096B
                                    6B
096C
      6C 096D
                6D 096E
                                    6F
                          6E 096F
0970
      70 0971
                71
                    0972
                          72 0973
                                    73
0974
      74
         0975
                75
                    0976
                          76
                             0977
                                    77
0978
      78
         0979
                79
                   097A
                          7A 097B
                                    7B
097C
                7D 097E
                          7E 097F
      7C
         097D
                                    7F
0980
      00
         0981
                00
                   0982
                          00
                              0983
                                    00
0984
      00
         0985
                00 0986
                          00 0987
                                    00
```

Βλέπουμε πως πράγματι, το πρόγραμμά μας είναι ορθό.

## Ερώτημα (β)

Στο ερώτημα αυτό μετράμε πόσους άσσους έχουμε σε όλους τους δυαδιχούς αριθμούς από το 0 - 127. Θεωρητικά, αυτός ο αριθμός είναι 448, αφού οι αριθμοί από το 0 - 127 περιέχουν 7 δυαδικά ψηφιά ο καθένας (σύνολο 7\*127=896) εκ των οποίων τα μισά είναι άσσοι. Για να τεστάρω το αποτέλεσμα του προγράμματός μου, φορτώνω τους B και C στη μνήμη και κατόπιν τους διαβάζω. C κώδικας που χρησιμοποιήθηκε φαίνεται στην επόμενη σελίδα:

```
IN 10H
LXI B,0000H ; Our 1s counter
MVI D,00H ; 0-127 Counter
MVI E,01H ; 1 tester
L2:
MOV A, D
ANA E
CPI 00H
JZ IFEND ; If 0
INX B
IFEND: MOV A, E
        RLC
        MOV E, A
        JNC L2
INR D
MVI E, 01H
MOV A, D
CPI 80H
JC L2
; We print the result
MOV A, C
STA 0A20H
MOV A, B
STA 0A21H
END
```

Πιο συγκεκριμένα, εκτελώ την πράξη AND με ένα-ένα τα ψηφία κάθε αριθμού κάθε φορά με τη μάσκα 00000001, 00000010, ... και αν το αποτέλεσμα είναι 1 αυξάνω τον μετρητή ενώ αν όχι συνεχίζω τις επαναλήψεις μέχρι να έρθει η ώρα του επόμενου αριθμού.

Παραχάτω, παραθέτουμε τα περιεχόμενα των θέσεων μνήμης 0A20 και 0A21 που είναι και το αποτέλεσμά μας.

```
0A18 00 0A19 00 0A1A 00 0A1B 00 0A1C 00 0A1D 00 0A1E 00 0A1F 00 0A20 C0 0A21 01 0A22 00 0A23 00 0A24 00 0A25 00 0A26 00 0A27 00 0A28 00 0A29 00 0A2A 00 0A2B 00
```

Άρα, σε 16αδιχή μορφή ο μετρητής μας είναι 01C0 που στο δεχαδιχό σύστημα είναι πράγματι το 448.

### Ερώτημα (γ)

Στο ερώτημα (γ) καλούμαστε να γράψουμε κώδικα assembly που εξετάζει πόσοι αριθμοί των δεδομένων βρίσκονται στο διάστημα 10H έως 60H. Θεωρητικά, το πλήθος αυτό είναι 60H - 10H + 1H = 51H. Δηλαδή, 81 στο δεκαδικά σύστημα. Ο κώδικας που συντάξαμε φαίνεται παρακάτω:

```
IN 10H
MVI B,00H ; 0-127 counter
MVI D,00H ; Counter of nums
L1:
MOV A, B
CPI 10H ; Is B < 10H?
JC ISEND; If yes, loop if not end
CPI 60H; Is B < 60H?
JC YES; If yes, 10H<=X<60H
JZ YES; X = 60H
JNZ ISEND ; else loop
YES:
INR D
ISEND:
INR B
MOV A, B
CPI 80H
JC L1
; VISUALIZATION OF RESULT IN MEMORY
MOV A, D
STA 0830H
END
```

Τέλος, μετά την εκτέλεση του προγράμματος βλέπουμε πως στην μνήμη μας στην διεύθυνση 0830Η υπάρχει πράγματι ο αριθμός 51Η.

| 0828 | 00 | 0829 | 00 | 082A | 00 | 082B | 00 |
|------|----|------|----|------|----|------|----|
| 082C | 00 | 082D | 00 | 082E | 00 | 082F | 00 |
| 0830 | 51 | 0831 | 00 | 0832 | 00 | 0833 | 00 |
| 0834 | 00 | 0835 | 00 | 0836 | 00 | 0837 | 00 |
| 0838 | 00 | 0839 | 00 | 083A | 00 | 083B | 00 |

```
MVI C,64H; Timer initialization C = 100 (total ms in 0.1 seconds)
          MVI D,00H; Counter initialisation D = 0
   INIT_ON: LDA 2000H ; Read the input from the dip switches
          CPI 7FH ; 0111 1111b
          JNC INIT_ON ; If MSB set, switch initially ON
   OFF_STATE: LDA 2000H; Read the input from the dip switches
6
          CPI 7FH ; 0111 1111b
          JC OFF_STATE ; if MSB unset, repeat OFF_STATE
   ON_STATE: MOV A,D ; Move counter D to A
          CPI 00H; Check if D is equal to 0
          JZ SKIP_DEL ; If yes, skip delay
11
12
          PUSH D ; Push D to stack in case it changes in the call
          CALL DELB ; Delay for 0.1 seconds
14
          POP D ; Pop D from stack
          DCR D ; Decrease counter D
15
          JNZ SKIP_DEL; If D != O, skip updating the LEDs
16
          MVI A,FFH ; Set A to 1111 1111b to clear all LEDs
17
          STA 3000H; Output A to the (negative logic) LED's
18
   SKIP_DEL: LDA 2000H; Read the input from the dip switches
          CPI 7FH ; 0111 1111b
20
          JNC ON_STATE ; if MSB set, repeat ON_STATE
21
          MVI D,32H; Counter initialisation D = 50 (50*0.1 = 20 seconds)
   DELAY: XRA A ; Clear A to open all LED's
23
          STA 3000H; Output A to the (negative logic) LED's
          PUSH D ; Push D to stack in case it changes in the call
25
26
          CALL DELB ; Delay for 0.1 seconds
          POP D ; Pop D from stack
27
          LDA 2000H; Read the input from the dip switches
28
29
          CPI 7FH ; 0111 1111b
          JNC ON_STATE; If MSB set, repeat ON_STATE (and continue delaying)
30
31
          DCR D ; Decrease the counter
          JNZ DELAY ; If not reached 10 seconds, repeat DELAY state
32
33
          MVI A,FFH ; Set A to 1111 1111b to clear all LEDs
          STA 3000H; Output A to the (negative logic) LED's
34
          JMP OFF_STATE ; Stop delaying and go to OFF_STATE
35
   END
```

Στην αρχή, αρχικοποιούμε τις μεταβλητές του timer και του μετρητή. Αν αρχικά είναι ΟΝ παραμένουμε στο ΟΝ μέχρι να αλλάξει το dip switch του MSB. Μόλις αλλάξει, προχωράμε στο κύριο μέρος του κώδικα και όπου η κατάσταση ξεκινάει ως OFF. Όταν η κατάσταση αλλάξει σε ON, αν δεν είχε ήδη συμβεί OFF-ON-OFF, οπότε ο μετρητής είναι 0, τότε επαναλαμβάνουμε. Αν δεν είναι 0, τότε περιμένουμε 0.1sec, την διακριτική ικανότητα που ζητείται, και μειώνουμε τον μετρητή. Αν ο μετρητής έγινε 0, τότε κάνουμε clear τα LEDs. Στη συνέχεια ελέγχουμε αν η κατάσταση άλλαξε σε OFF (οπότε έγινε OFF-ON-OFF), και αν ναι, αρχικοποιούμε τον μετρητή στην κατάλληλη τιμή για να έχουμε ανοιχτά τα LEDs για 20 δευτερόλεπτα. Αν η κατάσταση αλλάξει σε ON, επαναλαμβάνουμε ό,τι αναφέραμε προηγουμένως και επανεκινούμε τον μετρητή αν αυτό χρειαστεί με νέα μετάβαση σε OFF. Αλλιώς, αν απλά περάσουν τα 20 δευτερόλεπτα ενώ βρισκόμαστε στο OFF, σβήνουμε τα λαμπάκια και γυρίζουμε στο label OFF\_STATE, επαναλαμβάνοντας τον όλο αλγόριθμο.

#### $3^{\eta}$ A $\Sigma$ KH $\Sigma$ H

### Ερώτημα i.

Ο κώδικας assembly για το ερώτημα αυτό φαίνεται παρακάτω:

```
MVI B,00H
SWITCH_LIGHTS:
MOV A, B
RRC
CMA.
STA 3000H
INPUT:
LDA 2000H; Read input in register A
MOV C, A ; Store input
MVI B,01H ; Position of open switch
SEARCH: ; Rotate right till overflow
MOV A, B
RLC ; Position update
MOV B, A
JC SWITCH LIGHTS
MOV A, C
RRC
MOV C, A
JC SWITCH LIGHTS
JNC SEARCH
END
```

Η ιδέα είναι να στρίβουμε το input δεξιόστροφα μέχρι να υπερχειλίσει, κάνοντας το ανάποδο σε έναν άλλο καταχωρητή που θα μας υποδείξει τι θα ανάψουμε. Το πρόγραμμα αυτό είναι συνεχούς λειτουργίας και έτσι αλλάζει κατάσταση κάθε φορά που πειράζουμε τους διακόπτες του simulator.

### Ερώτημα ii.

Ο κώδικας assembly για το ερώτημα αυτό φαίνεται παρακάτω:

```
MVI A,00H
SWITCH_LIGHTS:
STA 3000H
INPUT:
CALL KIND
MOV B,A ; Store input in B register
CPI 00H; Comp input with zero
JZ INPUT ; If zero, new input
CPI 09H ; Comp with 9
JC L1 ; If 1 <= input < 9, valid
JNC INPUT ; Else new input
Ll:
MVI A,00H ; Init A
DCR B
JZ SWITCH LIGHTS
INR A ; Next led on too
JMP L2
END
```

Αρχικά ξεκινάμε με όλα τα λαμπάκια αναμμένα (δε διευκρυνίζεται κάτι στην εκφώνηση περί αρχικής κατάστασης οπότε επιλέγουμε τυχαία αυτή). Το πρόγραμμα είναι συνεχούς λειτουργίας. Οπότε κάθε φορά περιμένει το input του χρήστη από το πληκτρολόγιο και αρχικά εκτελεί ελέγχους για το αν αυτό είναι επιτρεπτό. Κατόπιν, αφαιρούμε συνεχώς 1 από την είσοδο (που έχει αποθηκευτεί στον καταχωρωτή Β) για να δούμε πόσα led θα ανάψουμε (κάθε μείωση είναι ένα rotation RLC). Μόλις βρούμε το αποτέλεσμα, η εκτέλεση μεταβαίνει στο άναμμα των LED και στην συνέχει πάλι στο input... Ο κώδικας περιέχει και σχόλια.

### Ερώτημα iii.

Ο κώδικας για το ερώτημα αυτό φαίνεται παρακάτω:

```
IN 10H; No memory protection
2
   LXI D,OBOOH ; Big address, no conflict
5 | MVI A,10H; Idle char (fist four pos)
   STA OBOOH
   STA OBO1H
   STA OBO2H
   STA OBO3H; Idle is one byte long
   ; NOW READING
11
12
   LINE_O:
13
       MVI A, FEH ; Line 111111110
14
       STA 2800H
       LDA 1800H ; Read column
16
17
       MVI B,07H
       ANA B ; O the first 5 MSB
18
       MVI B,86H
       CPI 06H ; INSTR_STEP???
20
       JZ SHOW
       MVI B.85H
22
       CPI 05H ; FETCH PC???
23
       JZ SHOW
       ; Ignore HDWR_STEP
```

```
26
    LINE_1:
27
       MVI A,FDH ; Line 11111101
28
29
        STA 2800H
       LDA 1800H ; Read column
30
        MVI B,07H
31
        ANA B ; 0 the first 5 MSB
32
        MVI B,84H
33
       CPI 06H ; INSTR_STEP???
34
        JZ SHOW
35
36
       MVI B,80H
       CPI 05H ; FETCH PC???
37
        JZ SHOW
38
       MVI B,82H
39
       CPI 03H ; FETCH ADRS???
40
41
        JZ SHOW
42
    LINE_2:
43
       MVI A, FBH ; Line 11111011
44
        STA 2800H
45
46
        LDA 1800H ; Read column
        MVI B,07H
47
        ANA B ; 0 the first 5 MSB
48
        MVI B,00H
49
        CPI 06H ; 0???
50
        JZ SHOW
51
       MVI B,83H
53
        CPI 05H ; STORE/INCR???
        JZ SHOW
54
        MVI B,81H
55
       CPI 03H ; INCR???
56
        JZ SHOW
57
58
59
60
    LINE_3:
       MVI A,F7H ; Line 11110111
61
        STA 2800H
62
63
       LDA 1800H ; Read column
        MVI B,07H
64
65
        ANA B ; O the first 5 MSB
       MVI B,01H
66
        CPI 06H ; 1???
67
       JZ SHOW
68
       MVI B,02H
69
       CPI 05H ; 2???
70
        JZ SHOW
71
        MVI B,03H
72
       CPI 03H ; 3???
73
74
       JZ SHOW
75
    LINE_4:
76
77
        MVI A, EFH ; Line 11101111
        STA 2800H
78
        LDA 1800H; Read column
79
80
        MVI B,07H
        ANA B ; 0 the first 5 MSB
81
82
        MVI B,04H
       CPI 06H ; 4???
83
84
        JZ SHOW
       MVI B,05H
85
        CPI 05H ; 5???
86
87
        JZ SHOW
        MVI B,06H
88
        CPI 03H ; 6???
89
        JZ SHOW
90
91
    LINE_5:
92
       MVI A, DFH ; Line 11011111
93
94
        STA 2800H
       LDA 1800H ; Read column
95
        MVI B,07H
96
        ANA B ; O the first 5 MSB
97
        MVI B,07H
98
        CPI 06H ; 7???
99
        JZ SHOW
100
101
        MVI B,08H
       CPI 05H ; 8???
102
```

```
JZ SHOW
103
104
        MVI B,09H
        CPI 03H ; 9???
        JZ SHOW
    LINE_6:
108
        MVI A, BFH ; Line 10111111
        STA 2800H
111
        LDA 1800H ; Read column
        MVI B,07H
        ANA B ; O the first 5 MSB
        MVI B,OAH
114
        CPI 06H ; A???
        JZ SHOW
        MVI B, OBH
        CPI 05H ; B???
118
        JZ SHOW
119
        MVI B, OCH
120
        CPI 03H : C???
        JZ SHOW
    LINE_7:
124
        MVI A,7FH ; Line 01111111
125
        STA 2800H
126
        LDA 1800H; Read column
127
128
        MVI B,07H
        ANA B ; O the first 5 MSB
130
        MVI B, ODH
        CPI 06H ; D???
        JZ SHOW
132
        MVI B, OEH
134
        CPI 05H ; E???
        JZ SHOW
        MVI B.OFH
136
137
        CPI 03H ; F???
        JZ SHOW
138
    JMP START ; If nothing pressed, again
141
    SHOW:
        LXI H,0B04H; Continue store block
143
        MOV A,B
144
        ANI OFH ; 4 LSB
145
        MOV M,A
146
        INX H
147
        MOV A.B
148
        ANI FOH ; 4 MSB
149
        R.I.C
        RLC
        RLC
        RLC
        MOV M, A
154
        CALL STDM
        CALL DCD
157
        JMP START
158
    END
```

Πρώτα από όλα αφαιρούμε την προστασία της μνήμης. Στην συνέχεια αποθηκεύουμε στα 4 LSB τον κενό χαρακτήρα (από αυτά που θα προβάλλουμε στην οθόνη). Ουσιαστικά, όπως λέει και η εκφώνηση θέλουμε μόνο τα 2 τελευταία. Στην συνέχεια, εφαρμόζουμε τις οδηγίες του εγχειρηδίου του μLAB για την κάθε γραμμή του πληκτρολογίου. Αφού την επιλέξουμε (STA με το κατάλληλο byte), διαβάζουμε τις στήλες και αποθηκεύουμε κάθε πιθανό πλήκτρο στον καταχωρητή Β. Ελέγχουμε αν όντως το αντίστοιχο πλήκτρο πιέστηκε και κατόπιν μεταφέρουμε την εκτέλεση στην ετικέτα που είναι υπεύθυνη για την εμφάνιση μηνυμάτων στην οθόνη. Εκεί, πάλι σύμφωνα με το εγχειρήδιο του προσομοιωτή εκτελούμε τα κατάλληλα βήματα προκειμένου να εμφανιστεί ο χαρακτήρα που πιέστηκε στην οθόνη.

ΣΗΜΕΙΩΣΗ: Οι χαρακτήρες τύπου FETCH\_PC αναπαρίστανται από τους δεκαεξαδικούς αριθμούς που τους αντιστοιχούν.

#### $4^{\eta} A\Sigma KH\Sigma H$

```
LXI SP,OBBOH ; Initialize Stack Pointer
LDA 2000H
```

```
MOV B, A ; B[O] = BO
5
       RRC ; A[0] = A0
       MOV C,A; C = (2000H) >> 2
6
       ANA B ; A[O] = AO AND BO
       MOV D, A; D[O] = AO AND BO. STORED IN D (for now)
       MOV A,C; A = (2000H) >> 2
       RRC ; A = (2000H) >> 3
       MOV B,A; B[O] = B1
       RRC : A \Gamma O 7 = A 1
13
       MOV C,A; C = (2000H) >> 4
       ANA B ; A[O] = A1 AND B1
       MOV E,A; E[O] = A1 AND B1. STORED IN E
17
       MOV A,C; A = (2000H) >> 5
       RRC ; A = (2000H) >> 6
18
19
       MOV B,A; B[O] = B2
20
       RRC ; A[0] = A2
21
       MOV C,A; C = (2000H)>>6
22
       XRA B ; A[O] = A2 XOR B2
23
       MOV\ H,A; H[O] = A2 XOR B2. STORED IN H (for now)
       MOV A,C; A = (2000H) >> 5
25
       RRC ; A = (2000H) >> 6
26
       MOV B, A; B[0] = B3
28
       RRC ; A[0] = A3
       MOV C,A; C = (2000H) >> 7
30
       XRA B ; A[0] = A3 XOR B3
       MOV L, A; L[O] = A3 XOR B3. STORED IN L
33
34
       MOV A,D ; A[O] = AO AND BO
       ORA E ; A[O] = (AO \ AND \ BO) \ OR \ (A1 \ AND \ B1)
35
       MOV D,A ; D[O] = (AO AND BO) OR (A1 AND B1). STORED IN D
36
37
       MOV A,H; A[O] = A2 XOR B2
38
       ORA L ; A[O] = (A2 \ XOR \ B2) \ OR \ (A3 \ XOR \ B3)
39
       MOV\ H,A; H[O] = (A2 XOR B2) OR (A3 XOR B3). STORED IN H
40
       MVI B,01H; B = 0000 \ 0001b. Initialise Mask
42
       MVI C,00H; C = 0000 0000b. Initialise Result
43
44
       MOV A,L ; A[O] = X_3
45
       CALL LOAD1 ; C[1] = X_3, C[else] = 0
46
47
       MOV A,H ; A[O] = X_2
       CALL LOAD1 ; C[1] = X_2, C[2] = X_3, C[else] = 0
49
50
       MOV A,E ; A[O] = X_1
51
       CALL LOAD1; C[1] = X_1, C[2] = X_2, C[3] = X_3
       MOV A,D; A[O] = X_3
54
       CALL LOAD2 ; C[0..3] = X_{-}[0..3], C[else] = 0
56
       MOV A,C; Move result to A
       {\ensuremath{\mathsf{CMA}}} ; Complement A to get result in negative logic
       STA 3000H ; Output the result to the LEDs
60
    LOAD1: ; C \le 1, C[1] = A[0], C[0] = 0
61
       ANA B ; Get\ bit
62
       ORA C ; Add to result. Updated result in A
63
       RLC; Shift A 1 position to the left
64
       MOV C, A ; Updated result in C
65
       RET ; Return to main program
66
67
   LOAD2: ; C[O] = A[O]
68
69
       ANA B ; Get bit
70
       ORA C ; Add to result. Updated result in A
71
       {\tt MOV} {\tt C}, {\tt A} ; Updated result in {\tt C}
73
       RET ; Return to main program
74
   END
75
```

Υπολογίζουμε τη λογική συνάρτηση για το κάθε bit εξόδου, ξεκινώντας τόσο στο input όσο και στο output τους υπολογισμούς από δεξιά προς τα αριστερά. Αποθηκεύουμε τις τιμές εισόδου που διαβάζουμε σε διαφορετικούς καταχωρητές, κάνοντας κατάλληλες ολισθήσεις ώστε οι τιμές αληθείας που θέλουμε να βρίσκονται πάντα στο LSB των καταχωρητών. Όταν

διαβάσουμε τα  $A_0$ ,  $B_0$ ,  $A_1$ ,  $B_1$  υπολογίζουμε παράλληλα τα  $X_0$ ,  $X_1$ . Ομοίως, όταν διαβάσουμε τα  $A_2$ ,  $B_2$ ,  $A_3$ ,  $B_3$ , υπολογίζουμε τα  $X_2$ ,  $X_3$ . Επαναχρησιμοποιούμε όποιον καταχωρητή πλέον δεν χρειαζόμαστε. Στο τέλος, έχοντας σε διαφορετικούς καταχωρητές τα  $A_1$  bits της εξόδου, τα φορτώνουμε όλα με τη σωστή σειρά σε έναν καταχωρητή, τον οποίο στέλνουμε με ανάποδη λογική στα LEDs της εξόδου.

#### $5^{\eta}$ A $\Sigma$ KH $\Sigma$ H

και συνεπώς θα έχουμε εγγραφή από στη μνήμη.

Στο σχήμα που παραθέτουμε παραπάνω φαίνεται η εσωτεριχή οργάνωση μίας μνήμης SRAM 256x64 bit. Ισχύει ότι, 256x4 = 16x16x4 =  $2^4$ x2<sup>4</sup>x4. Συνεπώς, προχειμένου να επιλέξουμε μία από τις 16 γραμμές της μνήμης χρειαζόμαστε 4 bit (A4, A5, A6, A7). Καθένα από τα bit εισόδου/εξόδου (I/O1, I/O2, I/O3, I/O4) είναι συνδεδεμένο σε έναν πολυπλέχτη 16-σε-1, οι οποίοι είναι υπεύθυνοι για την επιλογή μίας εχ των 16 τετράδων στις οποίες θα εγγραφούν ή από τις οποίες θα αναγνωστούν. Πιο συγχεχριμένα, η επιλογή των τετράδων ελέγχεται από τα 4 LSB της διεύθυνσης μνήμης A0, A1, A2, A3. Μένει να μπορούμε να επιλέξουμε πότε θα γίνεται ανάγνωση χαι πότε εγγραφή στον πίναχα της μνήμης. Αυτό γίνεται με την βοήθεια απομονωτών χαι των σημάτων  $\overline{CS}, \overline{RD}, \overline{WE}$ . Λεπτομερέστερα, μόλις το  $\overline{CS}$  γίνει  $0, \eta$  μνήμη ενεργοποιείται (το 1 εχ των τριών ορισμάτων των πυλών  $\overline{AND}$  γίνεται 1). Εφόσον, πλέον  $\overline{CS} = 0$ ) τα σήματα  $\overline{WE} = 1$  χαι  $\overline{RD} = 0$ , ενεργοποιούνται οι απομονωτές των γραμμών σημασμένων με read χαι συνεπώς θα έχουμε ανάγνωση από τη μνήμη. Τέλος,

στην περίπτωση που τα σήματα  $\overline{WE}=0$  και  $\overline{RD}=1$ , ενεργοποιούνται οι απομονωτές των γραμμών σημασμένων με write



## $6^{\eta}$ ASKHSH

Αρχικά, παρουσιάζουμε παρακάτω τον χάρτη μνήμης του συστήματος που δίνεται στην εκφώνηση.

| 0000H |            | 0000Н<br>07FFH | ROM1a<br>2Kx8 bits |
|-------|------------|----------------|--------------------|
|       | DOM        | 0800H          | ROM1a<br>2Kx8 bits |
|       | ROM<br>8KB | 0FFFH<br>1000H | ZIVAO DIIS         |
|       |            |                | ROM2<br>4Kx8 bits  |
| 1FFFH |            | 1FFFH          |                    |
| 2000H |            | 2000H          | SRAM1              |
|       | RAM        | 27FFH<br>2800H | 2Kx8 bits          |
|       | 4KB        | 2800H          | SRAM2              |
| 2FFFH |            | 2FFFH          | 2Kx8 bits          |

| Χάρτης Μνήμης |         |    |    |    |    |    |        |     |   |   |   |   |   |   |   |   |   |
|---------------|---------|----|----|----|----|----|--------|-----|---|---|---|---|---|---|---|---|---|
| Περιοχή ROM   |         |    |    |    |    |    |        |     |   |   |   |   |   |   |   |   |   |
| Memory        | Address | 15 | 14 | 13 | 12 | 11 | 10     | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ROM1a         | 0000    | 0  | 0  | 0  | 0  | 0  | 0      | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (2KB)         | 07FF    | 0  | 0  | 0  | 0  | 0  | 1      | 1   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| ROM1b         | 0800    | 0  | 0  | 0  | 0  | 1  | 0      | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (2KB)         | 0FFF    | 0  | 0  | 0  | 0  | 1  | 1      | 1   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| ROM2          | 1000    | 0  | 0  | 0  | 1  | 0  | 0      | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (4KB)         | 1FFF    | 0  | 0  | 0  | 1  | 1  | 1      | 1   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|               |         | •  |    |    |    | I  | Ιεριοχ | ήRO | M |   |   |   |   |   |   |   |   |
| Memory        | Address | 15 | 14 | 13 | 12 | 11 | 10     | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RAM1          | 2000    | 0  | 0  | 1  | 0  | 0  | 0      | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (2KB)         | 27FF    | 0  | 0  | 1  | 0  | 0  | 1      | 1   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| RAM2          | 2800    | 0  | 0  | 1  | 0  | 1  | 0      | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (2KB)         | 2FFF    | 0  | 0  | 1  | 0  | 1  | 1      | 1   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

α) Το λογικό διάγραμμα της μνήμης και η συνδεσμολογία με τα απαιτούμενα σήματα από το system bus του μΕ 8085, όταν η αποκωδικοποίηση των διευθύνσεων γίνεται με αποκωδικοποιητή 3:8 (74LS138) φαίνεται παρακάτω.



β) Ενώ όταν η αποχωδιχοποίηση γίνεται μόνο με λογιχές πύλες, το διάγραμμα και οι αντίστοιχες διασυνδέσεις φαίνονται παραχάτω.



## $7^{\eta}$ A $\Sigma$ KH $\Sigma$ H

Πρώτα από όλα, παρουσιάζουμε τον χάρτη μνήμης μαζί τα bits των διευθύνσεων του χάρτη μνήμης.

| Χάρτης Μνήμης |         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------|---------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Memory        | Address | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ROM1          | 0000    | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (8KBytes)     | 1FFF    | 0  | 0  | 0  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| RAM1          | 2000    | 0  | 0  | 1  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (4KBytes)     | 2FFF    | 0  | 0  | 1  | 0  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| RAM2          | 3000    | 0  | 0  | 1  | 1  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (4KBytes)     | 3FFF    | 0  | 0  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| RAM3          | 4000    | 0  | 1  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (4KBytes)     | 4FFF    | 0  | 1  | 0  | 0  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| ROM2          | 5000    | 0  | 1  | 0  | 1  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| (8KBytes)     | 6FFF    | 0  | 1  | 1  | 0  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

Παρατηρώντας το χάρτη, βλέπουμε πως το MSB  $A_{15}$  δεν μεταβάλλεται. Επομένως θα το χρησιμοποιήσουμε στην επίτρεψη. Κατόπιν, βλέπουμε πως τα bit  $A_0-A_{11}$  παίρνουν όλες τις δυνατές τους τιμές, δημιουργώντας σελίδες των 4 KByte. Έτσι, μένουν 3 bit, τα  $A_{12},A_{13},A_{14}$  τα οποία θα επιλέγουν μεταξύ των σελίδων αυτών. Οι πρώτες 2 σελίδες αφορούν τα πρώτα 8 KByte της ROM, οι επόμενες 3 τις 3 RAM και οι 2 ακόμα τα υπόλοιπα 8 KByte της ROM. Η τελευταία σελίδα μπορεί να χρησιμοποιηθεί και για το input 70H καθώς και για την memory-mapped I/O στην 7000H. Για την ROM, επειδή την χωρίζουμε εικονικά, πρέπει κάπως να διαχωρίσουμε τις 2 περιοχές της. Για αυτό χρησιμοποιούμε το bit A14 το οποίο της το περνάμε και αυτό σαν είσοδο. Για να ολοκληρθεί η διευθυνσιοδότηση εκτός των bit A0-A11 χρησιμοποιούμε το A12 για την πρώτη περιοχή και το A13 για την δεύτερη επιλέγοντας τα κάθε φορά με βάση ποια περιοχή ενεργοποιείται (MUX με selector το A14). Το κύκλωμα απεικονίζεται παρακάτω:

